<template>
  <el-card class="box-card">
    <div slot="header" class="clearfix">
      <span>更换头像</span>
    </div>
    <div>
      <!-- 图片，用来展示用户选择的头像 -->
      <img class="the_img" v-if="!this.avatar" src="../../assets/images/avatar.jpg" alt="" />
      <img class="the_img" v-else :src="this.avatar" alt="">
      <!-- 按钮区域 -->
      <div class="btn-box">
        <input type="file" accept="image/*" style="display: none" ref="iptRef" @change="onFileChange" />
        <el-button type="primary" icon="el-icon-plus" @click="chooseImg">选择图片</el-button>
        <el-button type="success" icon="el-icon-upload" @click="uploadFn" :disabled="avatar === ''">上传头像</el-button>
      </div>
    </div>
  </el-card>
</template>

<script>
import { updateAvatarAPI } from '@/api'
export default {
  name: 'UserAvatar',
  data () {
    return {
      avatar: ''
    }
  },
  methods: {
    // 选择图片->点击事件 -> 让选择框出现
    chooseImg () {
      // 模拟点击行为  this.$refs.iptRef获取的是原生 dom标签
      this.$refs.iptRef.click()
    },
    // 在选择框中选择图片后触发的改变事件
    onFileChange (e) {
      const files = e.target.files
      if (files.length === 0) {
        // 没有选择图片
        this.avatar = ''
      } else {
        // 选择了图片
        // 目标： 选择的图片文件 要给img 标签上做纯前端的预览
        // img标签的src值
        // * 只能是图片的"链接地址"(外界http://开头，图片文件相对路径)
        // * 或者是图片的base64字符串(而且字符串还必须是data:image/png;base64,
        // 图片转base64字符串)

        // 解决方案1： 文件 -> 内存临时地址(这个地址只能在js里内存里不能发给后台)
        // 语法: URL.createOnjectURL(文件)
        // 返回值: 内存临时地址
        // 使用URL.createObjURL()来转换文件变成图片地址(纯前端本地)
        // this.avatar = URL.createObjectURL(files[0])
        console.log(files[0])
        // 方案二：文件 -> base64字符串(此字符串是可以发送给后端的)
        // 1. 创建 FileReader 对象
        const fr = new FileReader()
        // 2. 调用 readAsDataURL 函数，读取文件内容
        fr.readAsDataURL(files[0]) // 传入文件对象开始读
        // 3. 监听 fr 的 onload 事件
        fr.onload = e => { // 等待把文件读成base64字符串后会触发onload事件函数
          // 4. 通过 e.target.result 获取到读取的结果，值是字符串（base64 格式的字符串）
          this.avatar = e.target.result
        }
      }
    },
    // 上传图片
    async uploadFn () {
      const { data: res } = await updateAvatarAPI(this.avatar)
      if (res.code !== 0) return this.$message.error(res.$message)
      // 更新头像成功
      this.$message.success(res.message)
      // getUserInfoActions
      this.$store.dispatch('initUserInfo')
      console.log(res)
    }
  }
}
</script>

<style lang="less" scoped>
.btn-box {
  margin-top: 10px;
}
.preview {
  object-fit: cover;
}
.the_img {
  width: 350px;
  height: 350px;
}
</style>
